home *** CD-ROM | disk | FTP | other *** search
/ Developer CD Series 2000 April: Mac OS SDK / Dev.CD Apr 00 SDK1.toast / Development Kits / Mac OS / Thread Manager / Sample Applications / 68k Examples / Traffic Threads / TrafficLight.h < prev    next >
Encoding:
C/C++ Source or Header  |  1994-11-17  |  5.4 KB  |  174 lines  |  [TEXT/MPS ]

  1. /*------------------------------------------------------------------------------
  2. #
  3. #    Apple Macintosh Developer Technical Support
  4. #
  5. #    MultiFinder-Aware Simple Sample Application
  6. #
  7. #    Sample
  8. #
  9. #    Sample.h    -    Rez and C Include Source
  10. #
  11. #    Copyright © Apple Computer, Inc. 1989-1990
  12. #    All rights reserved.
  13. #
  14. #    Versions:    
  15. #
  16. ------------------------------------------------------------------------------*/
  17.  
  18. /*    These #defines correspond to values defined in the Pascal source code.
  19.     Sample.c and Sample.r include this file. */
  20.  
  21.  
  22. #define kMinSize    120                /* application's minimum size (in K) */
  23.  
  24. /*    We made the preferred size bigger than the minimum size by 12K, so that
  25.     there would be even more room for the scrap, FKEYs, etc. */
  26.  
  27. #define kPrefSize    350                /* application's preferred size (in K) */
  28.  
  29. #define    rMenuBar    128                /* application's menu bar */
  30. #define    rAboutAlert    128                /* about alert */
  31. #define    rUserAlert    129                /* error user alert */
  32. #define    rWindow        128                /* application's window */
  33. #define rStopRect    128                /* rectangle for Stop light */
  34. #define rGoRect        129                /* rectangle for Go light */
  35.  
  36. /* nicer error user alert */
  37. #define    rUserAlertContinue    130
  38. #define kErrStrings            130
  39. #define eCommandFailed        1
  40.  
  41. /* Dhrystone Dialog */
  42. #define kDhrystoneDLOG        131
  43. #define kMessageItem        1
  44. #define kDhrystoneString    131
  45.  
  46. /* kSysEnvironsVersion is passed to SysEnvirons to tell it which version of the
  47.    SysEnvRec we understand. */
  48.  
  49. #define    kSysEnvironsVersion        1
  50.  
  51. /* kOSEvent is the event number of the suspend/resume and mouse-moved events sent
  52.    by MultiFinder. Once we determine that an event is an osEvent, we look at the
  53.    high byte of the message sent to determine which kind it is. To differentiate
  54.    suspend and resume events we check the resumeMask bit. */
  55.  
  56. #define    kOSEvent                app4Evt    /* event used by MultiFinder */
  57. #define    kSuspendResumeMessage    1        /* high byte of suspend/resume event message */
  58. #define    kResumeMask                1        /* bit of message field for resume vs. suspend */
  59. #define    kMouseMovedMessage        0xFA    /* high byte of mouse-moved event message */
  60. #define    kNoEvents                0        /* no events mask */
  61.  
  62. /* The following constants are used to identify menus and their items. The menu IDs
  63.    have an "m" prefix and the item numbers within each menu have an "i" prefix. */
  64.  
  65. #define    mApple                    128        /* Apple menu */
  66. #define    iAbout                    1
  67.  
  68. #define    mFile                    129        /* File menu */
  69. #define    iNew                    1
  70. #define    iClose                    4
  71. #define    iQuit                    12
  72.  
  73. #define    mEdit                    130        /* Edit menu */
  74. #define    iUndo                    1
  75. #define    iCut                    3
  76. #define    iCopy                    4
  77. #define    iPaste                    5
  78. #define    iClear                    6
  79.  
  80. #define    mLight                    131        /* Light menu */
  81. #define    iStop                    1
  82. #define    iGo                        2
  83.  
  84. /*    1.01 - kTopLeft - This is for positioning the Disk Initialization dialogs. */
  85.  
  86. #define kDITop                    0x0050
  87. #define kDILeft                    0x0070
  88.  
  89. /*    1.01 - kMinHeap - This is the minimum result from the following
  90.     equation:
  91.         
  92.         ORD(GetApplLimit) - ORD(ApplicZone)
  93.         
  94.     for the application to run. It will insure that enough memory will
  95.     be around for reasonable-sized scraps, FKEYs, etc. to exist with the
  96.     application, and still give the application some 'breathing room'.
  97.     To derive this number, we ran under a MultiFinder partition that was
  98.     our requested minimum size, as given in the 'SIZE' resource. */
  99.      
  100. #define kMinHeap                21 * 1024
  101.     
  102. /*    1.01 - kMinSpace - This is the minimum result from PurgeSpace, when called
  103.     at initialization time, for the application to run. This number acts
  104.     as a double-check to insure that there really is enough memory for the
  105.     application to run, including what has been taken up already by
  106.     pre-loaded resources, the scrap, code, and other sundry memory blocks. */
  107.      
  108. #define kMinSpace                8 * 1024
  109.  
  110. /* kExtremeNeg and kExtremePos are used to set up wide open rectangles and regions. */
  111.  
  112. #define kExtremeNeg                -32768
  113. #define kExtremePos                32767 - 1 /* required to address an old region bug */
  114.  
  115. /* these #defines are used to set enable/disable flags of a menu */
  116.  
  117. #define AllItems    0b1111111111111111111111111111111    /* 31 flags */
  118. #define NoItems        0b0000000000000000000000000000000
  119. #define MenuItem1    0b0000000000000000000000000000001
  120. #define MenuItem2    0b0000000000000000000000000000010
  121. #define MenuItem3    0b0000000000000000000000000000100
  122. #define MenuItem4    0b0000000000000000000000000001000
  123. #define MenuItem5    0b0000000000000000000000000010000
  124. #define MenuItem6    0b0000000000000000000000000100000
  125. #define MenuItem7    0b0000000000000000000000001000000
  126. #define MenuItem8    0b0000000000000000000000010000000
  127. #define MenuItem9    0b0000000000000000000000100000000
  128. #define MenuItem10    0b0000000000000000000001000000000
  129. #define MenuItem11    0b0000000000000000000010000000000
  130. #define MenuItem12    0b0000000000000000000100000000000
  131.  
  132.  
  133. /* Dhrystone stuff */
  134.  
  135. #ifndef FOR_REZ
  136.  
  137. /* Measurements should last at least about 2 seconds */
  138. #define Too_Small_Time (2*60)
  139. #define Mic_secs_Per_Second     1000000.0
  140.  
  141. typedef enum {Ident_1, Ident_2, Ident_3, Ident_4, Ident_5} Enumeration;
  142. #define Null 0 
  143. typedef int     One_Thirty;
  144. typedef int     One_Fifty;
  145. typedef char    Capital_Letter;
  146. typedef char    Str_30 [31];
  147. typedef int     Arr_1_Dim [50];
  148. typedef int     Arr_2_Dim [50] [50];
  149.  
  150. typedef struct Rec_Type 
  151.     {
  152.     struct Rec_Type        *Ptr_Comp;
  153.     Enumeration            Discr;
  154.     union {
  155.         struct
  156.             {
  157.             Enumeration Enum_Comp;
  158.             int            Int_Comp;
  159.             char        Str_Comp[31];
  160.             } var_1;
  161.         struct
  162.             {
  163.             Enumeration    E_Comp_2;
  164.             char        Str_2_Comp[31];
  165.             } var_2;
  166.         struct
  167.             {
  168.             char        Ch_1_Comp;
  169.             char        Ch_2_Comp;
  170.             } var_3;
  171.         } variant;
  172.     } Rec_Type, *Rec_Pointer;
  173.  
  174. #endif FOR_REZ